public class Test3 {
    //leetcode 53 最大子数组之和
    public int maxSubArray(int[] nums) {
        //dp[i]表示以i位置为结尾的所有子数组中最大的和
        int n = nums.length;
        int[] dp = new int[n];
        dp[0] = nums[0];
        int ret = nums[0];
        for (int i = 1; i < n; i++) {
            dp[i] = Math.max(nums[i],dp[i-1] + nums[i]);
            ret = Math.max(ret,dp[i]);
        }
        return ret;
    }
}
